<template>
  <div class="xtx-pagination">
    <!--    上一页 -->
    <a @click="changePager(myCurrentPage - 1 )" href="javascript:;" v-if=" myCurrentPage > 1">上一页</a>
    <!--    上一页禁用 -->
    <a href="javascript:;" class="disabled" v-else>上一页</a>
    <!--    省略号-->
    <span v-if="pager.start > 1">...</span>
    <!--    页码数 -->
    <a @click="changePager(i)" href="javascript:;" :class="{'active': i === myCurrentPage }"
       v-for="i in pager.btnArr" :key="i">{{ i }}</a>
    <!--    省略号-->
    <span v-if="pager.end < pager.pageCount">...</span>
    <!--    下一页-->
    <a @click="changePager(myCurrentPage + 1 )" href="javascript:;" v-if="myCurrentPage < pager.pageCount">下一页</a>
    <!--    下一页禁用-->
    <a href="javascript:;" v-else class="disabled">下一页</a>
  </div>
</template>
<script>
import { computed, ref, watch } from 'vue'

export default {
  name: 'XtxPagination',
  props: {
    total: {
      type: Number,
      default: 100
    },
    pageSize: {
      type: Number,
      default: 10
    },
    currentPage: {
      type: Number,
      default: 1
    }
  },
  setup (props, { emit }) {
    //  需要数据
    //  1.约定按钮的个数 5个, 如果成为动态的需要设置响应数据
    const count = 5
    //  2. 当前显示的页码
    const myCurrentPage = ref(1)
    //  3. 总页数 = 总条数 / 每一页条数 向上取整
    const myTotal = ref(100)
    const myPageSize = ref(10)
    //  其他数据（总页数，其实按钮、结束按钮、按钮数组）依赖上面数据得到
    const pager = computed(() => {
      // 总页数
      const pageCount = Math.ceil(myTotal.value / myPageSize.value)
      // 按钮个数和当前页码 ===》 起始按钮、结束按钮、按钮数组
      // 1.理想情况下：
      const offset = Math.floor(count / 2)
      let start = myCurrentPage.value - offset
      let end = start + count - 1
      // 2.如果其实页码小于1需要处理
      if (start < 1) {
        start = 1
        end = (start + count - 1) > pageCount ? pageCount : (start + count - 1)
      }
      //  3.如果结束页码大于总数需要处理
      if (end > pageCount) {
        end = pageCount
        start = (end - count + 1) < 1 ? 1 : (end - count + 1)
      }
      // 按钮个数
      const btnArr = []
      for (let i = start; i <= end; i++) {
        btnArr.push(i)
      }
      // 提供计算属性数据
      return {
        pageCount,
        btnArr,
        start,
        end
      }
    })
    // 监听props的变化，更新组件内部数据
    watch(props, () => {
      myTotal.value = props.total
      myPageSize.value = props.pageSize
      myCurrentPage.value = props.currentPage
    }, {
      immediate: true
    })
    // 切换分页函数
    const changePager = (page) => {
      myCurrentPage.value = page
      //  通知父组件
      emit('current-change', page)
    }
    return {
      myCurrentPage,
      myTotal,
      myPageSize,
      pager,
      changePager
    }
  }
}
</script>
<style scoped lang="less">
.xtx-pagination {
  display: flex;
  justify-content: center;
  padding: 30px;

  > a {
    display: inline-block;
    padding: 5px 10px;
    border: 1px solid #e4e4e4;
    border-radius: 4px;
    margin-right: 10px;

    &:hover {
      color: @xtxColor;
    }

    &.active {
      background: @xtxColor;
      color: #fff;
      border-color: @xtxColor;
    }

    &.disabled {
      cursor: not-allowed;
      opacity: 0.4;

      &:hover {
        color: #333
      }
    }
  }

  > span {
    margin-right: 10px;
  }
}
</style>
